
1 What is claimed is: 

2 1 . A method of fast fingerprint search space partitioning and prescreening, said method 

3 comprising the steps of: 

4 inputting the contents of a fingerprint repository comprising file fingerprints for index creation; 

5 creating an index based on each minutia and selected neighbors of each minutia in each file 

6 fingerprint in the repository; 

7 searching the index to identify all minutiae which correspond to the minutiae in a search 

8 fingerprint; and 

*JL analyzing results of this search to determine which file fingerprints contributed the most minutiae 

r<§ with the best correspondence to the minutiae in the search fingerprint. 

lSfj 2. A method according to Claim 1 , wherein each file fingerprint of the fingerprint repository 

ltS includes the following data: the number of minutiae in the fingerprint; and for each minutia: the 
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1 base angle of the minutia in a frame of reference whose angular orientation to and permissible 

14 deviation from the axis of the finger of the fingerprint is pre-defined; the Cartesian coordinates 

LlfJ (X, Y) of the minutia relative to the same frame of reference; the minutia index of the nearest 

W neighboring minutia in each of eight octants wherein each octant comprises a 45 degree wedge 

1=| and the first octant of which is centered on the base angle of the minutia and wherein the 

M nearest neighboring minutia are know as octant neighbors; a count of friction ridges between 

19 the minutia and each of its eight octant neighbors; an Euclidean distance between the minutia 

20 and each of its eight octant neighbors and the difference between the base angle of the minutia 

21 and the base angle of each of its eight octant neighbors. 

22 3. A method according to Claim 2, wherein the index created from the repository of file 

23 fingerprints comprises the following information: 1) an index of each subject in the repository; 2) 

24 an index of each finger of each subject; and 3) an index of the minutia for each finger of each 

25 subject in the repository. 

26 4. A method according to Claim 1, wherein if an index already exists, subjects of the repository 

27 are compared with subjects of the existing index to determine whether a subject of the 

28 repository is already in the index to prevent duplication of subjects in the index. 
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1 5. A method according to Claim 1, wherein the step of creating the index includes creating 

2 neighbor combinations for each finger of each subject of the repository wherein a neighborhood 

3 combination is based on selecting 2 of eight octant neighbors to produce 28 possible 

4 combinations per finger. 

5 6. A method according to Claim 5, wherein the step of creating the index further includes the 

6 step of creating a hash table file for each finger-neighbor combination. 

7 7. A method according to Claim 6, wherein the hash table file includes the following information: 

8 an index of a hash list node in the hash list file and the number of hash list nodes associated 

9 with a hash code 

10 8. A method according to Claim 7, wherein the hash code is at least a 15-bit hash code. 

f I 9. A method according to Claim 5, wherein the step of creating the index further includes the 

1# step of creating a hash list file for each finger-neighbor combination wherein a hash list 

ti comprises N hash list nodes, where N is a function of the number of minutiae in the repository, 

W plus any room needed for repository expansion. 
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fl> 10. A method according to Claim 9, wherein each hash list node contains the following data: a 

W hash code to identify the hash list file, the number of populated repository index slots in the 

|| hash list file and a plurality of repository index slots. 

W 1 1 . A method according to Claim 10, wherein the optimum number of slots in a node is a 

f 9 function of the hash code distribution which is a function of the fingerprint characteristics in the 

20 repository. 

21 12. A method according to Claim 5, wherein the step of creating the index further includes 

22 creating one hash list node used file for each finger-neighbor combination wherein a hash list 

23 node used file is a bookkeeping device which tracks which hash list nodes in the file are 

24 populated at any given time. 

25 13. A method according to Claim 5, wherein each neighbor combination of each minutia of 

26 each finger of each subject of the repository which is not already in the index is added into the 

27 index. 





1 14. A method according to Claim 1 , wherein the step of searching the index comprises the 

2 steps of identifying all subjects that contain minutiae and neighbor combinations similar to 

3 minutiae and neighbor combinations of the search fingerprint and creating a list of candidate 

4 subjects. 

5 15. A method according to Claim 15, wherein, when all of the minutiae and neighbor 

6 combinations have been processed, the step of analyzing the search results comprises scoring 

7 and ranking each of the candidate subjects 

8 16. A method according to Claim 15, wherein the step of analyzing the search results further 

9 include generating a list of the most likely matches from all of the candidate subjects of the list. 

10 17. A method according to Claim 14, wherein the following data for each finger is used for the 

lslj search: 1) the number of times a given finger is visited during the search; 2) the number of 

W individual minutiae that participate in a match; 3) the degree to similarity between the 

orientation of the minutia of the search fingerprint and a file fingerprint; and 4) a score which is 

iW proportional to the degree of match between the search fingerprint and the file fingerprint 
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L|j 18. A method according to Claim 17, wherein after the data is collected during the search, the 

P6 step of analyzing the search comprises formulating a raw score according to the following 

lijf) equation: Raw Score=(VisitCount-MinutiaCount)*(max(degree of similarity between the 

ljSP orientation of the minutia of the search fingerprint and the file fingerprint)). 
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IS 19. A method according to Claim 18, wherein the raw score for each finger of each candidate 

20 subject is normalized using statistical techniques appropriate for the observed exponential 

21 distribution of the raw scores. 

22 20. A method according to Claim 19 wherein the standard deviation of the entire set of scores 

23 for the finger is calculated and the each raw score is then divided by the standard deviation to 

24 produce a normalized exponential score for the Subject/Finger and the normalized exponential 

25 scores for each finger of each candidate mate are combined to produce a multi-finger score by 

26 summation. 

27 21. A method according to Claim 20, wherein candidate mates are scanned from first to last 

28 and if the multi-finger score for a particular candidate mate exceeds a pre-determined threshold, 

29 that subject is appended to the result list. 
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22. A method according to Claim 21, wherein the list is sorted in descending multi-finger-score 
order to create a list of candidate mate subjects ordered from most likely (highest score) through 
least likely (lowest score). 
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